const db = require('../db/index')

// 导入 bcryptjs 加密
const bcrypt = require('bcryptjs')

// 获取用户信息接口
exports.getUserInfo = (req, res) => {
  const sql = `select id, username, nickname, email, user_pic from ev_users where id = ?`
  db.query(sql, req.user.id, (err, results) => {
    if (err) return res.cc(err)
    if (results.length !== 1) return res.cc('获取用户信息失败！')
    res.send({
      status: 0,
      message: '获取用户信息成功！',
      data: results[0]
    })
  })
}

// 更新用户信息的接口
exports.updateUserInfo = (req, res) => {
  const sql = `update ev_users set ? where id = ?`
  db.query(sql, [req.body, req.body.id], (err, results) => {
    if (err) return res.cc(err)
    if (results.affectedRows !== 1) return res.cc('更新用户信息失败！')
    return res.cc('更新用户信息成功！', 0)
  })
}

// 重置密码的接口
exports.updatePassword = (req, res) => {
  const sql = `select * from ev_users where id = ?`
  db.query(sql, req.user.id, (err, results) => {
    if (err) return res.cc(err)
    if (results.length !== 1) return res.cc('用户不存在！')
    // 判断提交的旧密码是否正确 bcrypt.compareSync(提交的密码，数据库中的密码) 
    const compareResult = bcrypt.compareSync(req.body.oldPwd, results[0].password)
    if (!compareResult) return res.cc('原密码错误！')
    // 对新密码 bcrypt 加密
    const newPwd = bcrypt.hashSync(req.body.newPwd, 10)
    const sqlStr = `update ev_users set password = ? where id = ?`
    db.query(sqlStr, [newPwd, req.user.id], (err, results) => {
      if(err) return res.cc(err)
      if(results.affectedRows !== 1) return res.cc('更新密码失败！')
      res.cc('更新密码成功！', 0)
    })
  })
}

  // 更新头像的接口
  exports.updateAvatar = (req, res) => {
    const sql = 'update ev_users set user_pic=? where id=?'
    db.query(sql, [req.body.avatar, req.user.id],(err, results) => {
      if(err) return res.cc(err)
      if(results.affectedRows !== 1) return res.cc('更新头像失败！')
      return res.cc('更新头像成功！', 0)
    })
  }
